

# UG-2864HSWEG01 128X64 Evaluation Kit User Guide

Writer: James Wang

E-mail: James\_Wang@univision.com.tw

**Version: Preliminary** 



### **Contents**

| 1. REVISION HISTORY                             | 3  |
|-------------------------------------------------|----|
| 2. EVK Schematic                                | 4  |
| 3. Symbol define                                | 5  |
| 4. TIMMING CHARACTERISTICS                      | 6  |
| 4.1 8080-Series MPU parallel Interface          | 7  |
| 4.2 6800-Series MPU parallel Interface          | 9  |
| 4.3 SPI Interface                               | 10 |
| 4.4 IIC Interface                               | 11 |
| 5. EVK use introduction                         | 14 |
| 6.Power down and Power up Sequence              | 17 |
| 7. How to use SSD1306 module                    | 18 |
| 7.1 Initial Step Flow                           | 18 |
| 7.2 RD recommend Initial Code for IIC Interface | 19 |
| 7.2.1 Sub Function for IIC Interface.           | 20 |



# 1. REVISION HISTORY

| Preliminary 0.0 |
|-----------------|
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |

### 悠景科技股份有限公司

#### 2. EVK Schematic



| SSD1306<br>Pin Name | I <sup>2</sup> C Interface | 6800-parallel<br>interface<br>(8 bit) | 8080-parallel<br>interface<br>(8 bit) | 4-wire Serial<br>interface | 3-wire Serial<br>interface |
|---------------------|----------------------------|---------------------------------------|---------------------------------------|----------------------------|----------------------------|
| BS0                 | 0                          | 0                                     | 0                                     | 0                          | 1                          |
| BS1                 | 1                          | 0                                     | 1                                     | 0                          | 0                          |
| BS2                 | 0                          | 1                                     | 1                                     | 0                          | 0                          |

Note  $^{(1)}$  0 is connected to  $V_{SS}$   $^{(2)}$  1 is connected to  $V_{DD}$ 

\* R1 should be replaced as  $560k\Omega$  while supplying 9V on VCC externally.

#### 悠景科技股份有限公司

#### 3. Symbol define

VCC: Power supply for panel driving voltage.

VBAT: Power supply for panel driving voltage(Embedded Charge Pump).

**VDD**: Power supply for core logic operation.

**VSS**: This is ground pin.

BS0~BS2: MUC bus interface selection pin(Page 4 Table7-1).

**CS**: This pin is chip select input(active LOW).

RES: This pin is reset signal input(active LOW).

D/C: This is DATA/COMMAND control pin. When it is Pulled HIGH, the data at D[0~7] is treated as data. When it is pulled LOW, the data at D[0~7] will be transferred to the command register.

In I2C mode, this pin acts as SA0 for slave address select.

R/W: This is read/write control input pin connecting to the MCU interface.

When interface to a 6800-series microprocessor, Read mode will be carried out when this pin is pulled HIGH and write mode when low.

When interface to an 8080-microprocessor, this pin when be the data Write input.

When serial interface is selected, this pin must be connected to Vss.

E/RD: When interface to a 6800-series microprocessor, this pin will be used as the Enable(E) signal.

When interface to an 8080-microprocessor, this pin receives the Read(RD#)signal.

D0~D7: These are 8-bit bi-directional data bus to be connected to the microprocessor's data bus.

When serial interface mode is selected, D0(SCLK) will be the serial clock input,D1(SDIN) will be the serial data input,D2 should be left opened.

When I2C mode is selected, D1(SDAin) AND D2(SDAout) should be tied together, D0(SCL) is the I2Cclock input

IREF: This is segment output current reference pin.

**VCOMH**: This pin for COM signal deselected level voltage.

A capacitor should be connected between this pin and VSS.

VBAT: It should be connected to VDD (Charge Pump DISABLE) or could be connected to individual power voltage supply.

VBAT= 3.4~4.2V.(Charge Pump ENABLE)

C1P/C1N: It should be connected a capacitor.

C2P/C2N: It should be connected a capacitor.

VBREF: It should be connected VSS. It should be kept NC if it is not used.

BS[2:0]:MCU bus interface selection pins.



IREF: This is segment output current reference pin.

A resistor should be connected between this pin and VSS to maintain the IREF current at 12.5 uA.

FR: This pin outputs RAM write synchronization signal. Proper timing between MCU data writing and frame display timing can be achieved to prevent tearing effect. It should be kept NC if it is not used.

CL: This is external clock input pin.

When internal clock is enabled (i.e. HIGH in CLS pin), this pin is not used and should be connected to VSS. When internal clock is disabled (i.e. LOW in CLS pin), this pin is the external clock source input pin.

CLS: This is internal clock enable pin. When it is pulled HIGH (i.e. connect to VDD), internal clock is enabled. When it is pulled LOW, the internal clock is disabled; an external clock source must be connected to the CL pin for normal operation.

RES#: This pin is reset signal input. When the pin is pulled LOW, initialization of the chip is executed. Keep this pin HIGH (i.e. connect to VDD) during normal operation.

CS#: This pin is the chip select input. (Active LOW)



### 4. IIC INTERFACES DESCRIPTIONS & TIMMING CHARACTERISTICS

#### 4.1 80-Series MPU parallel Interface

#### WRITE CHARACTERISTICS



Figure 1 80-Series MPU parallel Interface Write Timing Diagram

(VDD = 2.8V, Ta = 25 °C)

| Symbol                                 | Parameter                                                     | Conditions | Related Pins | MIN      | TYP | MAX | Unit |
|----------------------------------------|---------------------------------------------------------------|------------|--------------|----------|-----|-----|------|
| t <sub>cyc</sub>                       | Write cycle time                                              | -          | WRB          | 100      | -   | -   | ns   |
| t <sub>cads</sub><br>t <sub>cadh</sub> | Address and Select setup time<br>Address and Select hold time | -          | CSB,A0       | 0        | -   | -   | ns   |
| t <sub>wads</sub><br>t <sub>wadh</sub> | Address setup time<br>Address hold time                       | -          | A0           | 50<br>20 | -   | -   | ns   |
| t <sub>cws</sub><br>t <sub>cwh</sub>   | Select setup time<br>Select hold time                         | -          | CSB          | 10<br>10 | -   | -   | ns   |
| t <sub>wrbl</sub>                      | Write Low pulse width                                         | -          | WRB          | 30       | -   | -   | ns   |
| t <sub>csbh</sub>                      | Select High pulse width                                       | -          | CSB          | 10       | -   | -   | ns   |
| t <sub>wats</sub><br>t <sub>wath</sub> | Data setup time<br>Data hold time                             | -          | D15 to D0    | 10<br>20 | -   | -   | ns   |

**Table 1 80-Series MPU parallel Interface Write Timing Characteristics** 



#### READ CHARACTERISTICS



Figure 2 80-Series MPU parallel Interface Read Timing Diagram

| Symbol                                 | Parameter                                                     | Conditions | Related Pins | MIN      | TYP | MAX | Unit |
|----------------------------------------|---------------------------------------------------------------|------------|--------------|----------|-----|-----|------|
| t <sub>cyc</sub>                       | Read cycle time                                               | -          | RDB          | 500      | -   | -   | ns   |
| t <sub>cads</sub><br>t <sub>cadh</sub> | Address and Select setup time<br>Address and Select hold time | -          | CSB,A0       | 0        | -   | -   | ns   |
| trads<br>tradh                         | Address setup time<br>Address hold time                       | -          | A0           | 50<br>20 | -   | -   | ns   |
| t <sub>ors</sub><br>t <sub>orh</sub>   | Select setup time<br>Select hold time                         | -          | CSB          | 10<br>10 | -   | -   | ns   |
| t <sub>rdbl</sub>                      | Read Low pulse width                                          | -          | RDB          | 250      | -   | -   | ns   |
| t <sub>csbh</sub>                      | Select High pulse width                                       | -          | CSB          | 10       | -   | -   | ns   |
| t <sub>rata</sub><br>t <sub>rath</sub> | Data output delay time<br>Data output hold time               | CL = 100pF | D15 to D0    | -<br>5   | -   | 200 | ns   |

Table 2 80-Series MPU parallel Interface Read Timing Characteristics



#### 4.2 6800-Series MPU parallel Interface

#### PARALLEL INTERFACE CHARACTERISTICS (6800-SERIES MPU)



Figure 3 68-Series MPU parallel Interface Write Timing Diagram

(Vss=0V, VDD=2.8V, Ta = 25°C) Conditions Related Pins MAX Symbol Parameter MIN TYP Unit Chip select setup time 10 tcsw68 CSB ns Chip select hold time t<sub>CSF68</sub> 10 Address setup time Α0 50 tases ns Address hold time t<sub>AH68</sub> RW 20 Write cycle time 160 tcyws8 Write High Time Ε 40 tpwnw68 ns Write Low Time t<sub>PWLW68</sub> 90 Read cycle time (Parameter read) 160 t<sub>CYR68</sub> Read High (Parameter read) Ε tpwhr68 40 ns Read Low (Parameter read) 90 tpwLR68 450 Read cycle time (Data read) t<sub>CYR68</sub> Read High (Data read) Ε 355 ns tpw+R68 Read Low (Data read) 90 t<sub>PWLR68</sub> 10 Data setup time t<sub>DS68</sub> ns Data hold time t<sub>DH68</sub> 20 D15 to D0 Data output access time 40  $t_{DOA68}$ CL = 30pFns toop68 Data output disable time 40 80

**Table 3 68-Series MPU parallel Interface Write Timing Characteristics** 



#### 4.3 SPI Interface

#### SERIAL INTERFACE CHARACTERISTICS



Figure 4 Serial peripheral interface Timing Diagram

(Vss=0V, VDD=2.8V, Ta = 25°C)

| Symbol                                                   | Parameter                                                                       | Conditions | Related Pins | MIN             | TYP         | MAX         | Unit |
|----------------------------------------------------------|---------------------------------------------------------------------------------|------------|--------------|-----------------|-------------|-------------|------|
| tcys<br>t <sub>WHS</sub><br>t <sub>WLS</sub>             | Serial clock cycle<br>High pulse width<br>Low pulse width                       | -          | SCLK         | 160<br>60<br>60 | -           | -           | ns   |
| toss<br>tons                                             | Data setup time<br>Data hold time                                               |            | SID (D1)     | 60<br>60        | -           | -           | ns   |
| t <sub>css</sub><br>t <sub>chs</sub><br>t <sub>chw</sub> | Chip select setup time<br>Chip select hold time<br>Chip select high pulse width | -          | CSB          | 60<br>65<br>45  | -<br>-<br>- | -<br>-<br>- | ns   |
| tscc                                                     | SCLK to Chip select                                                             | -          | SCLK, CSB    | 20              | -           | -           | ns   |

**Table 4 Serial peripheral interface Timing Characteristics** 

#### 悠景科技股份有限公司

#### 4.4 IIC Interface

#### MPU I<sup>2</sup>C Interface

The  $I^2C$  communication interface consists of slave address bit SA0,  $I^2C$ -bus data signal SDA (SDA<sub>OUT</sub>/D<sub>2</sub> for output /D<sub>1</sub> and SDA<sub>IN</sub> for input) and  $I^2C$ -bus clock signal SCL (D<sub>0</sub>). Both the data and clock signals must be connected to pull-up resistors. RES# is used for the initialization of device.

#### a) Slave address bit (SA0)

SSD1300 has to recognize the slave address before transmitting or receiving any information by the I<sup>2</sup>C-bus. The device will respond to the slave address following by the slave address bit ("SA0" bit) and the read/write select bit ("R/W#" bit) with the following byte format,

b<sub>7</sub> b<sub>8</sub> b<sub>5</sub> b<sub>4</sub> b<sub>3</sub> b<sub>2</sub> b<sub>1</sub> b<sub>0</sub> 0 1 1 1 1 0 SA0 R/W#

"SA0" bit provides an extension bit for the slave address. Either "0111100" or "0111101", can be selected as the slave address of SSD1300. D/C pin acts as SA0 for slave address selection. "R/W#" bit is used to determine the operation mode of the I<sup>2</sup>C-bus interface. R/W#=1, it is in read mode. R/W#=0, it is in write mode.

#### b) I2C-bus data signal (SDA)

SDA acts as a communication channel between the transmitter and the receiver. The data and the acknowledgement are sent through the SDA.

It should be noticed that the ITO track resistance and the pulled-up resistance at "SDA" pin becomes a voltage potential divider. As a result, the acknowledgement would not be possible to attain a valid logic 0 level in "SDA".

"SDA<sub>IN</sub>" and "SDA<sub>OUT</sub>" are tied together and serve as SDA. The "SDA<sub>IN</sub>" pin must be connected to act as SDA. The "SDA<sub>OUT</sub>" pin may be disconnected. When "SDA<sub>OUT</sub>" pin is disconnected, the acknowledgement signal will be ignored in the I<sup>2</sup>C-bus.

#### c) I2C-bus clock signal (SCL)

The transmission of information in the I<sup>2</sup>C-bus is following a clock signal, SCL. Each transmission of data bit is taken place during a single clock period of SCL.



### 悠景科技股份有限公司

#### Write mode for I2C

- The master device initiates the data communication by a start condition. The definition of the start condition is shown in Figure 6. The start condition is established by pulling the SDA from HIGH to LOW while the SCL stays HIGH.
- The slave address is following the start condition for recognition use. For the SSD1300, the slave address is either "b0111100" or "b0111101" by changing the SA0 to LOW or HIGH (D/C pin acts as SA0).
- The write mode is established by setting the R/W# bit to logic "0".
- 4) An acknowledgement signal will be generated after receiving one byte of data, including the slave address and the R/W# bit. Please refer to the Figure 7 for the graphical representation of the acknowledge signal. The acknowledge bit is defined as the SDA line is pulled down during the HIGH period of the acknowledgement related clock pulse.
- 5) After the transmission of the slave address, either the control byte or the data byte may be sent across the SDA. A control byte mainly consists of Co and D/C# bits following by six "0" 's.
  - a. If the Co bit is set as logic "0", the transmission of the following information will contain data bytes only.
  - b. The D/C# bit determines the next data byte is acted as a command or a data. If the D/C# bit is set to logic "0", it defines the following data byte as a command. If the D/C# bit is set to logic "1", it defines the following data byte as a data which will be stored at the GDDRAM. The GDDRAM column address pointer will be increased by one automatically after each data write.
- Acknowledge bit will be generated after receiving each control byte or data byte.
- 7) The write mode will be finished when a stop condition is applied. The stop condition is also defined in Figure 6. The stop condition is established by pulling the "SDA in" from LOW to HIGH while the "SCL" stays HIGH.







Please be noted that the transmission of the data bit has some limitations.

- The data bit, which is transmitted during each SCL pulse, must keep at a stable state within the "HIGH" period of the clock pulse. Please refer to the Figure 8 for graphical representations. Except in start or stop conditions, the data line can be switched only when the SCL is LOW.
- 2. Both the data line (SDA) and the clock line (SCL) should be pulled up by external resistors.







#### 5.EVK use introduction



Figure1 EVK PCB and OLED Module





Figure 2 The combination of the module and EVK
The SSD1306 is COG type package, that the connect pads are
on the bottom of the module connector. When finished
assembled the module and EVK, then push the locking pad to
lock the module. See the Figure 1 and Figure 2.
User can use leading wire to connect EVK with customer's
system. The example shows as Figure 3





Figure3 EVK with test platform

Note 1: It is the internal most positive voltage supply. In this sample is connected to power supply.

Note 2: Those are leading wire connect to control board. Those are data pin.(D0-D7)

Note 3: Those are leading wire connect to control board. Those are control pin.

(DC, CS, RD, WR, RES)

# 悠景科技股份有限公司

#### 6. Power down and Power up Sequence

To protect OLED panel and extend the panel life time, the driver IC power up/down routine should include a delay period between high voltage and low voltage power sources during turn on/off. Such that panel has enough time to charge up or discharge before/after operation.

#### **Power up Sequence:**



- 2. Send Display off command
- 3. Driver IC Initial Setting
- 4. Clear Screen
- 5. Power up Vcc
- 6. Delay 100ms (when V<sub>DD</sub> is stable)
- 7. Send Display on command



#### **Power down Sequence:**

- 1. Send Display off command
- 2. Power down V<sub>DDH</sub>
- 3. Delay 100ms (when  $V_{cc}$  is reach 0 and panel is completely discharges)
- 4. Power down V<sub>DD</sub>





#### 7. How to use SSD1306 module

7.1 Initial Step Flow



### 悠景科技股份有限公司

```
RD recommends Initial Code:
Internal setting (Charge pump)
{
WRITE_COMMAND(0xae);//--turn off oled panel
WRITE COMMAND(0x00);//---set low column address
WRITE COMMAND(0x10);//---set high column address
WRITE_COMMAND(0x40);//--set start line address
WRITE COMMAND(0x81);//--set contrast control register
WRITE COMMAND(0xcf);
WRITE_COMMAND(0xa1);//--set segment re-map 95 to 0
WRITE COMMAND(0xa6);//--set normal display
WRITE_COMMAND(0xa8);//--set multiplex ratio(1 to 64)
WRITE COMMAND(0x3f);//--1/64 duty
WRITE COMMAND(0xd3);//-set display offset
WRITE_COMMAND(0x00);//-not offset
WRITE_COMMAND(0xd5);//--set display clock divide ratio/oscillator frequency
WRITE_COMMAND(0x80);//--set divide ratio
WRITE_COMMAND(0xd9);//--set pre-charge period
WRITE_COMMAND(0xf1);
WRITE COMMAND(0xda);//--set com pins hardware configuration
WRITE_COMMAND(0x12);
WRITE_COMMAND(0xdb);//--set vcomh
WRITE COMMAND(0x40);
WRITE_COMMAND(0x8d);//--set Charge Pump enable/disable
WRITE COMMAND(0x14);//--set(0x10) disable
WRITE COMMAND(0xaf);//--turn on oled panel
}
```

### 悠景科技股份有限公司

#### **External setting**

```
{
WRITE COMMAND(0xae);//--turn off oled panel
WRITE_COMMAND(0x00);//---set low column address
WRITE_COMMAND(0x10);//---set high column address
WRITE COMMAND(0x40);//--set start line address
WRITE_COMMAND(0x81);//--set contrast control register
WRITE COMMAND(0x8f);
WRITE_COMMAND(0xa1);//--set segment re-map 95 to 0
WRITE_COMMAND(0xa6);//--set normal display
WRITE_COMMAND(0xa8);//--set multiplex ratio(1 to 64)
WRITE_COMMAND(0x3f);//--1/64 duty
WRITE COMMAND(0xd3);//-set display offset
WRITE_COMMAND(0x00);//-not offset
WRITE_COMMAND(0xd5);//--set display clock divide ratio/oscillator frequency
WRITE_COMMAND(0x80);//--set divide ratio
WRITE_COMMAND(0xd9);//--set pre-charge period
WRITE_COMMAND(0x22);
WRITE_COMMAND(0xda);//--set com pins hardware configuration
WRITE COMMAND(0x12);
WRITE_COMMAND(0xdb);//--set vcomh
WRITE_COMMAND(0x40);
WRITE COMMAND(0x8d);//--set Charge Pump enable/disable
WRITE_COMMAND(0x10);//--set(0x14) Enable
WRITE COMMAND(0xaf);//--turn on oled panel
}
```